<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.8/dist/vue.js" type="text/javascript"></script>
</head>
<body>
    <!-- 
        收集表单数据:
            若:<input type="text"/>，则v-model收集的是value值，用户输入的就是value值。
            若:<input type="radio"/>，则v-model收集的是value值，且要给标签配置value值。
            若:<input type="checkbox"/>
                1.没有配置input的value属性，那么收集的就是checked（勾选or未勾选，是布尔值）
                2.配置input的value属性;
                    (1)v-model的初始值是非数组，那么收集的就是checked（勾选or未勾选，是布尔值)
                    (2)v-model的初始值是数组，那么收集的的就是value组成的数组
            备注:v-model的三个修饰符:
                lazy:失去焦点再收集数据
                number:输入字符串转为有效的数字
                trim:输入首尾空格过滤

     -->
    <div id="box">
        <form @submit="submit">
            账号：<input type="text" v-model.trim="account"><br><br>
            密码：<input type="password" v-model="password"><br><br>
            年龄：<input type="number" v-model.number="age"><br><br>
            性别：
            男<input type="radio" name="sex" v-model="sex" value="male">
            女<input type="radio" name="sex" v-model="sex" value="female"><br><br>
            爱好：
            java <input type="checkbox" v-model="hobby" value="java">
            c <input type="checkbox" v-model="hobby" value="c">
            python <input type="checkbox" v-model="hobby" value="python">
            javascript <input type="checkbox" v-model="hobby" value="javascript"><br><br>
            所处城市：
            <select v-model="city">
                <option value="">请选择城市</option>
                <option value="beijing">北京</option>
                <option value="shanghai">上海</option>
                <option value="tianjin">天津</option>
                <option value="guizhou">贵州</option>
            </select><br><br>
            其他信息：
            <textarea v-model.lazy="others"></textarea><br><br>
            <input type="checkbox" v-model="agree">同意<a href="#">《用户协议》</a>
            <button>提交</button>
        </form><br>
        
        <hr>


        <div>
            账号：<span>{{account}}</sp><br>
            密码：<span>{{password}}</sp><br>
            性别：<span>{{sex}}</sp><br>
            爱好：<span>{{hobby}}</sp><br>
            所处城市：<span>{{city}}</sp><br>
            其他信息：<span>{{others}}</sp><br>
            是否同意协议：<span>{{agree}}</sp>

        </div>
        
        
    </div>

    <script>
        Vue.config.productionTip = false;  //阻止vue在启动时生成生产提示
        //创建实例
        let vm = new Vue({
            el:"#box",
            data:{
                account:"",
                age:'',
                password:"",
                sex:"male",
                hobby:[],
                city:'tianjin',
                others:'',
                agree:"true"
            },
            methods: {
                submit(){
                    console.log(JSON.stringify(this._data));
                }
            },
        })
       
    </script>
</body>
</html>